# Memoria Practica 2

# Daniel Vilardell Igor Yuziv

# $\mathbf{\acute{I}ndex}$

| 1 | Dise | ny Jerarquic                           | 2  |
|---|------|----------------------------------------|----|
| 2 | Bloc | es ·                                   | 3  |
|   | 2.1  | Conversor binari a BCD de 8 bits       | 3  |
|   | 2.2  | Conversor de binari de 4 bits a 8 bits | 5  |
|   | 2.3  | Keygroup                               | 6  |
|   | 2.4  | Multiplicador                          | 8  |
|   | 2.5  | Bloc sel                               | 10 |
|   | 2.6  | Regs                                   | 12 |
|   | 2.7  | Control                                | 15 |
|   | 2.8  | Leds                                   | 15 |
|   | 2.9  | Programa principal                     | 17 |
|   | 2.10 | Final primera part                     | 19 |
| 3 | Part | extra                                  | 21 |
|   | 3.1  | Keygroup actualitzat                   | 21 |
|   | 3.2  |                                        | 22 |
|   | 3.3  | Control actualitzat                    | 25 |
|   | 3.4  | AperB actualitzat                      | 26 |
|   | 3.5  | MUX de 4 entrades                      | 28 |
|   | 3.6  | Programa principal extra               | 30 |
| 4 | Part | extra 2                                | 32 |
|   | 4.1  | Regs actualitzat                       | 32 |
|   | 4.2  |                                        | 33 |
|   | 4.3  | <del>-</del>                           | 33 |
|   |      | $\sim$                                 |    |

# 1 Diseny Jerarquic

El diseny te l'objectiu de multiplicar dos nombres compresos entre 0 i 9 entrats desde la graella de la placa. Nomes es podra entrar dades quan el estat intro estigui activat i nomes es veurà el resultat quan estiguem en el estat show. El estat intro s'activa clicant al boto asterisc mentres que el estat show s'activa si es clica el botó coixinet.

El diseny principal **ppal** el que fa es rebre la tecla premuda i el bloc keygroup ens diu si es un coixinet, un asterisc o un nombre. Control rebra aquesta informacio i decidirà si mostra o no el resultat en funcio del estat que esta. També decidirà si deixa entrar dades o no, i en el cas que si, la sortida intro sera 1 i el bloc regs actualitzara el nombre amb el rebut per la tecla. Finalment els valors de opA i opB guardats es multipliquen i si estem en el estat de show es mostra el resultat, i si no no es mostra.

El diseny exterior, que te la finalitat de comunicar el programa principal amb la placa desde la que introduim les dades funciona de la seguent manera. Es llegeixen les dades i s'introdueix la informacio que ens donen els blogs keytest i f\_div a ppal(si sha premut alguna tecla, quina sha premut, si sha de resetejar el sistema i el rellotge). El component ppal extreu opA, opB i el resultat del producte junt amb el bit de show, que ens dirà si mostrem el resultat i els leds vermells o no el mostrem i iluminem els leds verds.

El següent dibuix mostra un diagrama intuitiu del funcionament del sistema.



# 2 Blocs

#### 2.1 Conversor binari a BCD de 8 bits

Aquest component el farem amb vhdl i te l'objectiu de convertir la sortida del multiplicador de 8 bits a bcd per tal de mostrar a la placa. Te la seguent forma

 Flow Status
 Successful - Thu Nov 12 15:36:37 2020

 Quartus II Version
 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

 Revision Name
 Practica2\_2

 Top-level Entity Name
 BIN\_BCD\_8B

 Family
 Cyclone II

 Device
 EP2C35F672C6

Timing Models Final Met timing requirements Yes

 Total logic elements
 21 / 33,216 ( < 1 % )</td>

 Total combinational functions
 21 / 33,216 ( < 1 % )</td>

 Dedicated logic registers
 0 / 33,216 ( 0 % )

Total registers 0

Total pins 16 / 475 (3 %)

Total virtual pins 0

Total memory bits 0/483,840 (0%)Embedded Multiplier 9-bit elements 0/70 (0%)Total PLLs 0/4 (0%)

| Entrades | Descripció                                  |
|----------|---------------------------------------------|
| BIN(8)   | Nombre en binari que es vol convertir a BCD |
| Sortides | Descripció                                  |
| BCD(8)   | Nombre BIN convertit a BCD                  |



Podem veure que la simulacio funciona ja que la entrada en binari es igual que la sortida en hexadecimal, es a dir, en BCD.

#### 2.2 Conversor de binari de 4 bits a 8 bits

Aquest component el conectarem abans de la entrada del multiplicador per a transformar la entrada de 4 bits a la que necessita el multiplicador que es de 8 bits. Aquest l'unic que farà es omplir de 0 les primeres 4 entrades.



Flow Status Successful - Thu Nov 12 15:39:37 2020

Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

 Revision Name
 Practica2\_2

 Top-level Entity Name
 CONV4\_8

 Family
 Cyclone II

 Device
 EP2C35F672C6

Timing Models Final

Met timing requirements Yes

 Total logic elements
 0 / 33,216 (0 %)

 Total combinational functions
 0 / 33,216 (0 %)

 Dedicated logic registers
 0 / 33,216 (0 %)

Total registers 0

Total pins 12 / 475 (3 %)

Total virtual pins 0

Total memory bits 0 / 483,840 (0 %)
Embedded Multiplier 9-bit elements 0 / 70 (0 %)
Total PLLs 0 / 4 (0 %)

| Entrades | Descripció        |
|----------|-------------------|
| in(4)    | Nombre de 4 bits  |
| Sortides | Descripció        |
| out(8)   | Sortida de 8 bits |



Podem veure que el component funciona a partir de la simulació ja que els nombres son els mateixos que els de la sortida pero la sortida te 8 bits en contes de 4.

## 2.3 Keygroup

Aquest component ens dirà si la tecla premuda es el asterisc(AST), el coixinet(COI) o el nombre en BCD. A mes comproba abans que s'estigui prement alguna tecla amb la entrada nkey. Això ho fem amb el diseny comentat al previ que té la seguent forma.



Successful - Thu Nov 12 15:41:38 2020 Flow Status 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition Quartus II Version Revision Name Practica2 2 Top-level Entity Name keycode Family Cyclone II EP2C35F672C6 Device Timing Models Final Met timing requirements Yes Total logic elements 4/33,216(<1%) Total combinational functions 4/33,216 (<1%) Dedicated logic registers 0/33,216(0%) Total registers Total pins 8/475(2%) Total virtual pins Total memory bits 0 / 483,840 (0%) Embedded Multiplier 9-bit elements 0/70(0%) Total PLLs 0/4(0%)



Podem veure que la simulació mostra el correcte funcionament ja que desde la entrada 0 fins a la 9 informa que la entrada keycode es un nombre, de la A fins a la D els tres estan a 0, la entrada E diu que es un asterisc i la entrada F que es un coixinet.

La descripció del bloc en VHDL es la següent.

## 2.4 Multiplicador

Aquest component t'he l'objectiu de multiplicar 2 nombres de 4 bits i treure la sortida en BCD de 4 bits, es a dir, 8 bits de sortida. Per a fer això usarem el component creat a la practica anterior que et multiplicava dos nombres de 8 bits. A la entrada hi posarem un conversor de 4 a 8 bits i a la sortida un conversor de binari de 8 bits a BCD que crearem amb vhdl.



Flow Status Successful - Thu Nov 12 15:43:23 2020 Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition Revision Name Practica2\_2 Top-level Entity Name MULT\_BIN Family Cyclone II EP2C35F672C6 Device Timing Models Final Met timing requirements Yes 52 / 33,216 (< 1 %) Total logic elements Total combinational functions 52 / 33,216 (< 1 %) Dedicated logic registers 0/33,216(0%) Total registers Total pins 16 / 475 (3%) Total virtual pins Total memory bits 0 / 483,840 (0%) Embedded Multiplier 9-bit elements 0/70(0%) Total PLLs 0/4(0%)

| Entrades | Descripció                                            |
|----------|-------------------------------------------------------|
| a(4)     | Nombre a de 4 bits que es vol multiplicar             |
| b(4)     | Nombre b de 4 bits que es vol multiplicar             |
| Sortides | Descripció                                            |
| out (8)  | Sortida de 8 bits amb el resultat de la multiplicació |



Podem veure que funciona a partir de la simulacio ja que retorna la multiplicacio de a i b en BCD ja que representem la solucio en hexadecimal. La descripció del bloc en VHDL es la següent.

#### 2.5 Bloc sel

Aquest bloc te l'objectiu de retornar un bus de 7 bits amb el nombre a si la entrada show es 1, i 1111111 si la entrada show es 0;



 Flow Status
 Successful - Thu Nov 12 15:44:29 2020

 Quartus II Version
 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

 Revision Name
 Practica2\_2

 Top-level Entity Name
 SEL

 Family
 Cyclone II

 Device
 EP2C35F672C6

Timing Models Final Met timing requirements Yes

 Total logic elements
 8 / 33,216 ( < 1 % )</td>

 Total combinational functions
 8 / 33,216 ( < 1 % )</td>

 Dedicated logic registers
 0 / 33,216 ( 0 % )

Total registers 0

Total pins 17 / 475 (4 %)

Total virtual pins 0

 $\begin{array}{ll} \mbox{Total memory bits} & 0 \, / \, 483,840 \, (\, 0 \, \% \, ) \\ \mbox{Embedded Multiplier 9-bit elements} & 0 \, / \, 70 \, (\, 0 \, \% \, ) \\ \mbox{Total PLLs} & 0 \, / \, 4 \, (\, 0 \, \% \, ) \end{array}$ 

| Entrades | Descripció                                            |
|----------|-------------------------------------------------------|
| a(8)     | Nombre a seleccionar                                  |
| show(1)  | Nombre que decideix si la sortida es a o 11111111     |
| Sortides | Descripció                                            |
| out (8)  | Sortida de 8 bits amb el resultat de la multiplicació |

|            |       | Valu  | 0 ps     | 80.0 ns | 160,0 ns | 240,0 ns | 320,0 ns | 400 <sub>,</sub> 0 ns | 480,0 ns  | 560,0 ns | 640,0 ns | 720,0 ns  | 800 <sub>,</sub> 0 ns | 880,0 ns | 960 <sub>,</sub> 0 ns |
|------------|-------|-------|----------|---------|----------|----------|----------|-----------------------|-----------|----------|----------|-----------|-----------------------|----------|-----------------------|
|            | Name  | 20.2  | 20.25 ns |         |          |          |          |                       |           |          |          |           |                       |          |                       |
| <b>₽</b> 0 | ± a   | B 101 | 10110    | 10 X    | 11110100 | 00101110 | X 111111 | 10 X (                | 0110100 X | 01010010 | 10011000 | X 1010001 | 1 X 00                | 101011 X | 10100101              |
| ⊚9         | ± out | B 101 | 10110    | 110     | 11110100 | ж        | 11111111 |                       | 00110100  | 01010010 | *        | 11111111  | <b>X</b> 0            | 0101011  | 10100101              |
| <b>18</b>  | show  | U     |          |         |          | 1        |          | ШП                    |           |          |          |           | ШП                    |          |                       |

Podem veure que la simulacio funciona ja que si sel es 0 la sortida es 111111111 i si sel es 1 la sortida es a(8).

La descripció del bloc en VHDL es la següent.

```
LIBRARY ieee ;
USE ieee.std_logic_1164.ALL;
ENTITY sel_v IS PORT (
              IN STDLOGIC-VECTOR(7
                                      downto
                                             (0);
        show: IN STD_LOGIC;
                                     downto 0 ) ;
        o : OUT STD_LOGIC_VECTOR(7
END sel_v
;ARCHITECTURE arq OF sel_v IS
begin
process (show)
BEGIN
        if (show = '1') then o \le a;
        else o <= "11111111";
        end if;
END process ;
END arq;
```

### 2.6 Regs

Aquest component es un mòdul seqüencial síncron que te com a finalitat carregar i memoritzar els operands de la multiplicació opA i opB. Aquest, si la entrada intro es 1 i clk esta en el flanc de pujada i nrst esta activat, actualitzara els valors de opA i opB, posant a opA el valor entrat per keycode i a opB el antic valor de opA.



Flow Status Successful - Thu Nov 12 15:45:46 2020

Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

Revision Name Practica2\_2

 Top-level Entity Name
 regs

 Family
 Cyclone II

 Device
 EP2C35F672C6

Timing Models Final Met timing requirements Yes

 Total logic elements
 8 / 33,216 ( < 1 % )</td>

 Total combinational functions
 0 / 33,216 ( 0 % )

 Dedicated logic registers
 8 / 33,216 ( < 1 % )</td>

Total registers 8

Total pins 15 / 475 (3 %)

Total virtual pins 0

Total memory bits 0 / 483,840 (0 %)
Embedded Multiplier 9-bit elements 0 / 70 (0 %)
Total PLLs 0 / 4 (0 %)

| Entrades                 | Descripció                                              |
|--------------------------|---------------------------------------------------------|
| keycode(4)               | Marca la tecla que s'està prement                       |
| clk(1)                   | Es el rellotge que gestionara la memoria del sistema    |
| intro(1)                 | Indica si s'esta entrant un numero i s'ha d'actualitzar |
| $\operatorname{nrst}(1)$ | Marcara si s'ha de resetejar a 0 o no                   |
| Sortides                 | Descripció                                              |
| opA(8)                   | El valor del nombre A guardat                           |
| opB(8)                   | El valor del nombre B guardat                           |



Per a veure que el bloc funciona estem simulant la seguent situació. Primer es prem la tecla asterisc per tal d'introduir dades i despres s'introdueix un valor numeric 4 que es guarda en la variable opA. Despres s'introdueix un altre valor numeric 2 que fa que el 4 es guardi a opB i el 2 a opA. Al introduir el tercer valor aquest es posa a opA, el de opA passa a opB i el de opB desapareix. Mes tard premem el boto de reset que posa els dos valors a 0.

La descripció del bloc en VHDL es la següent.

```
library ieee;
use ieee.std_logic_1164.all;
entity regs_v is
     end regs_v;
architecture arq of regs_v is
signal a, b : std_logic_vector(3 downto 0);
begin
process (clk, nrst)
begin
     b <= a;
a <= keycode;
end process;
opA
opB <= b;
end arq;
```

#### 2.7 Control

Aquest component ens ve donat i esta escrit en vhdl. L'objectiu es guardar el estat en el que estem i indicar als altres moduls si es poden introduir nombres e iluminar els leds verds o mostrar el resultat i iluminar els leds vermells. En el cas que es premi coixinet el estat passarà a ser show, mentres que si es prem asterisc sera intro. Si es prem un nombre el estat es mantindra, i si estem en estat intro, enviara la senyal per a actualitzar els valors de opA i opB. Si estem en estat show no passara res.



La simulacio del component ens mostra que es correcte ja que quan es clica asterisc es passa en el estat st\_intro, en el que si cliquem un valor numeric el bit intro s'activa i el bit show esta desactivat. Quan cliquem coixinet podem veure al final que s'activa el bit de show. Quan cliquem reset es posa en el estat inicial que te show activat.

#### 2.8 Leds

Aquest component encendrà els leds vermells quan no es puguin introduir nombres i els verds quan si que es puguin introduir. Això es decidirà en funció de la entrada show.

```
LEDV <= "0000";

LEDG <= "1111";

else

LEDG <= "0000";

LEDV <= "1111";

end if;

end process;

end arq;
```

 Flow Status
 Successful - Thu Nov 12 15:50:56 2020

 Quartus II Version
 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

 Revision Name
 Practica2\_2

 Top-level Entity Name
 LEDS

 Family
 Cyclone II

 Device
 EP2C35F672C6

Timing Models Final Met timing requirements Yes

 Total logic elements
 0 / 33,216 (0 %)

 Total combinational functions
 0 / 33,216 (0 %)

 Dedicated logic registers
 0 / 33,216 (0 %)

Total registers 0

Total pins 9 / 475 (2 %)

Total virtual pins 0

Total memory bits 0/483.840 (0%)Embedded Multiplier 9-bit elements 0/70 (0%)Total PLLs 0/4 (0%)

| Entrades  | Descripció                                        |
|-----------|---------------------------------------------------|
| show      | Marca si es mostren els leds verds o els vermells |
| Sortides  | Descripció                                        |
| LED_GREEN | Actiu si els leds verds shan d'encendre           |
| LED_RED   | Actiu si els leds vermells shan d'encendre        |

|            | Name          | Value at | 0 ps    | 80.0 | ns   | 160.0 ns | 240,0 | ns : | 320.0 ns        | 400,0  | ns 480 <sub>.</sub> 0 | ns 560,0 |
|------------|---------------|----------|---------|------|------|----------|-------|------|-----------------|--------|-----------------------|----------|
|            |               | 20.25 ns | 20.25 n | IS   |      |          |       |      |                 |        |                       |          |
| <b>→</b> 0 | show          | UO       |         |      |      |          |       |      |                 |        |                       |          |
| <b>→</b> 0 | <b>■ LEDG</b> | B 1111   |         | 1111 | 0000 | X_       | 1111  | 0000 | $\perp X \perp$ | 1111 X | 0000                  | 1111     |
| € 6        | ± LEDV        | B 0000   |         | 0000 | 1111 | <b>X</b> | 0000  | 1111 | Ж               | 0000   | 1111                  | 0000     |
|            |               |          |         |      |      |          |       |      |                 |        |                       |          |

Com es pot veure la simulació funcione en funció de la entrada show.

#### 2.9 Programa principal

El programa principal ajunta tots els components mencionats anteriorment per tal de fer la part principal de la practica. El bloc keycode indica quin tipus de tecla es prem(AST, COI, BCD) es prem, que indica a control si ha de canviar d'estat o no. La entrada nkey marcarà si s'esta prement la tecla o no. Control decideixi si canviar el estat en funcio de la entrada com hem comentat abans.

La entrada keycode també s'envia a regs que actualitza o no els valors de opA i opB en funcio del estat actual. Aquests valors a la sortida es multipliquen en el multiplicador i el resultat s'envia a sel. En el cas que estiguem en el estat show treurà com a output el resultat, i en el cas que no hi siguem treura 11111111 cosa que farà que tots els llums del 7 bit quedin apagats.



Flow Status Successful - Thu Nov 12 15:57:10 2020

Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

 Revision Name
 Practica2\_2

 Top-level Entity Name
 ppal

 Family
 Cyclone II

Device EP2C35F672C6

Timing Models Final Met timing requirements Yes

 Total logic elements
 62 / 33,216 ( < 1 % )</td>

 Total combinational functions
 62 / 33,216 ( < 1 % )</td>

 Dedicated logic registers
 9 / 33,216 ( < 1 % )</td>

Total registers 9

Total pins 24 / 475 (5 %)

Total virtual pins 0

Total memory bits 0/483.840 (0%)Embedded Multiplier 9-bit elements 0/70 (0%)Total PLLs 0/4 (0%)

| Entrades   | Descripció                                                      |
|------------|-----------------------------------------------------------------|
| nkey(1)    | Marca si s'esta prement la tecla                                |
| keycode(4) | Marca la tecla que s'està prement                               |
| clk(1)     | Es el rellotge que gestionara la memoria del sistema            |
| nrst(1)    | Marcara si s'ha de resetejar a 0 o no                           |
| Sortides   | Descripció                                                      |
| show(1)    | Diu si s'ha de mostrar la sortida o no                          |
| opA(8)     | El valor del nombre A guardat a regs                            |
| opB(8)     | El valor del nombre B guardat a regs                            |
| res(8)     | Es el que s'ha de mostrar a la pantalla, la multiplicació o res |



Per a veure si funcionava em simulat el seguent escenari. Primer hem entrat un coixinet per a passar al estat e insersio de dades st\_input. Hem entrat el 5 que ha actualitzat el valor de opA, i despres el 3 que ha actualitzat el valor de opB. En tot aquesta estona la sortida res ha estat apagada ja que el bit de show esta desactivat. Hem introduit despres la entrada 7 que ha mogut la 3 a opB i ha eliminat la 5. Despres d'aixo hem premut la tecla coixinet que ens ha deixat veure el resultat de la multiplicació. Despres d'això hem premut la tecla reset que ha posat tots els valors a 0 i el estat de control a st\_show, es a dir, amb el bit de show activat.

# 2.10 Final primera part

Despres de fer i testejar tots els components per separats i junts ho conectem tot a la placa de la forma que hem comentat al principi de la practica amb el següent cirquit, assignant a les entrades de la placa els pins que toqui per a que funcioni el diseny.



Flow Status Successful - Thu Nov 12 15:59:01 2020

Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

Revision Name Practica2\_2
Top-level Entity Name CALCSIMULACIO

Family Cyclone II

Device EP2C35F672C6

Timing Models Final Met timing requirements Yes

 Total logic elements
 178 / 33,216 ( < 1 % )</td>

 Total combinational functions
 178 / 33,216 ( < 1 % )</td>

 Dedicated logic registers
 43 / 33,216 ( < 1 % )</td>

Total registers 43

Total pins 74 / 475 (16 %)

Total virtual pins 0

Total memory bits 0 / 483,840 (0 %)
Embedded Multiplier 9-bit elements 0 / 70 (0 %)
Total PLLs 0 / 4 (0 %)

#### 3 Part extra

Aquesta part hem realitzat els apartats a i c de la part extra. Per a fer aixo usarem el mateix diseny extern que el apartat anterior i per tant no el tornarem a explicar. L'unic que cambiem serà el programa principal junt amb tots els seus components que anirem explicant durant la memoria. Un petit resum es que per tal de saber si hem d'entrar A o B, dins de regs afegim 2 estats que ens ho indiquin. En el cas de que estiguem en la fase de introduir dades i haguem clicat A s'activara el estat de A. Per a la sortida(part c) calcularem totes les operacions demanades i amb un multiplexor seleccionarem la desitjada en funció de les tecles premudes durant el estat de show.

### 3.1 Keygroup actualitzat

Per tal de llegir, a mes dels nombres, lasterisc i el coixinet, les entrades A i B hem hagut d'afegir al codi VHDL dos sortides mes, A i B que diuen si la entrada keycode es refereix a aquestes tecles.

```
library ieee;
use ieee.std_logic_1164.all;
            port (nkey : in std_logic;
                           keycode: in std_logic_vector(3 downto 0); bcd, ast, coi, A, B, C, D: out std_logic);
end kevcode_extra:
architecture arq of keycode_extra is
            bcd \le '1' when (nkey = '0' and (keycode =
                                                                               "0000" or
                                                                keycode = "0001"
                                                                               "0010"
                                                                kevcode =
                                                                keycode
                                                                               "0100" or
                                                               keycode =
                                                                               "0101"
                                                               kevcode =
                                                                keycode
                                                                               "0111"
                                                               keycode =
                                                               keycode = "1000" c
keycode = "1001"))
                                                  else '0';
            ast <= '1' when nkey = '0' and keycode = "1110"
                                                  ,0 ,
            else '0 coi <= '1' when nkey = '0'
                                                  0; and keycode = "1111"
           coi <= '1' when nkey = '0' and keycode = "111 else '0';

A <= '1' when nkey = '0' and keycode = "1010" else '0';

B <= '1' when nkey = '0' and keycode = "1011"
           C <= '1' when nkey = '0 and keycode = "1011"

C <= '1' when nkey = '0' and keycode = "1100"

else '0';

D <= '1' when nkey = '0' and keycode = "1101"
                                         else '0';
end arg:
```

Flow Status Successful - Thu Nov 12 16:00:27 2020 Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition Revision Name Practica2 2 Top-level Entity Name keycode\_extra Family Cyclone II Device EP2C35F672C6 Timing Models Final Met timing requirements Yes Total logic elements 10 / 33,216 (< 1 %) Total combinational functions 10 / 33,216 (< 1 %) Dedicated logic registers 0/33,216(0%) Total registers Total pins 12 / 475 (3%) Total virtual pins Total memory bits 0 / 483,840 (0%) Embedded Multiplier 9-bit elements 0/70(0%) Total PLLs 0/4(0%)



El component funciona ja que fa el mateix que el keygroup anterior amb la diferencia que quan la entrada en hexadecimal es A s'activa la sortida A i quan es B s'activa la B.

# 3.2 Regs actualitzat

Aquí caldrà afegir dos estats, el estat introA i introB, que indicaran si s'ha d'introduir A o B. Si la sortida A de keygroup està activada el estat

passarà a ser introA, mentres que si es B passarà a ser introB. Si tant A com B son 0 es mantindrà igual.

Quan s'hagin d'introduir nombres ara, es mirarà en quin estat estem i si estem en el estat introA es canviarà el valor de A mentres que si estem en estat introB es canviarà B, sempre que el bit intro de la entrada estigui activat, ja que si no ho estigues, no s'haurien d'actualitzar els nombres ja que estariem en estat de show o la entrada seria asterisc o coixinet.

```
library ieee;
use ieee.std_logic_1164.all;
entity regs_extra2 is
         end regs_extra2;
architecture arq of regs_extra2 is
type machine is ( entrA, entrB);
signal aux1, aux2 : std_logic_vector(3 downto 0);
signal state : machine;
begin
begin
          if \ nrst = \c'0' \ then \ state <= entrA;
          case state is
              when entrA \Rightarrow if B = '1' and (intro = '1') then state \Leftarrow entrB;
               when entrB => if A = '1' and (intro = '1') then state <= entrA;
               end if;
         end case;
          case state is
              when entrA => if (nrst = '0')
then aux1 <= "0000"; aux2 <= "0000";
elsif (nrst='1') and (clk'event and clk = '1') and (intro = '1')
then aux1 <= keycode;
end if;
when entrB => if (nrst = '0') then aux1 <= "0000"; aux2 <= "0000";
                   end case;
end process;
opA <= aux1;</pre>
opB <= aux2;
end arq;
```

Flow Status Successful - Thu Nov 12 16:02:08 2020 Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition Revision Name Practica2 2 Top-level Entity Name regs\_extra2 Family Cyclone II Device EP2C35F672C6 Timing Models Final Met timing requirements No Total logic elements 49 / 33,216 (< 1 %) Total combinational functions 49 / 33,216 (< 1 %) Dedicated logic registers 8/33,216(<1%) Total registers 8 Total pins 17 / 475 (4%) Total virtual pins 0 Total memory bits 0 / 483,840 (0%) Embedded Multiplier 9-bit elements 0/70(0%) Total PLLs 0/4(0%)



La simulacio es replica el seguent comportament. En primer lloc es prem la tecla A per a dir que les dades s'introduiran dins de A. S'introdueixen les dades 2 i 4, les dos sobre A. Despres es prem la tecla B que fa que es puguin introduir dades dins de B a on introduim el nombre 7 que es guarda a opB. Finalment cliquem el boto de reset que posa els valors de la sortida a 0.

#### 3.3 Control actualitzat

Com que per tal de saber si hem d'actualitzar o no els estats de regs hem de saber si estem en el estat st\_intro o el estat st\_show, la sortida intro s'haura d'activar si estem a st\_intro i la entrada A o B estan activades. Per tant fem la següent modificació al codi.

```
library ieee;
use ieee.std_logic_1164.all;
entity Control_extra is
  port( clk, nrst, bcd, ast, coi, A, B, C, D : in std_logic;
    intro, show : out std_logic );
end Control_extra;
architecture arq of Control_extra is
  type machine is ( st_show, st_intro);
  signal state : machine;
   process(clk, nrst)
          if nrst='0' then state <= st_show;
elsif (clk'event and clk='1') then</pre>
                     case state is
                                ate is
when st_show => if ast='1' then state <= st_intro; end if;
when st_intro => if coi='1' then state <= st_show;
                                                                         else state <= st_intro;
end if;</pre>
          end case;
end if;
end process;
intro <= '1' when state=st_intro and (bcd='1' or A = '1' or B = '1') else '0'; show <= '1' when state=st_show else '0';
show <= '1' when state=st_show else
end arq;
```

```
Flow Status
                                  Successful - Thu Nov 12 16:04:07 2020
Quartus II Version
                                  9.1 Build 350 03/24/2010 SP 2 SJ Web Edition
Revision Name
                                  Practica2_2
Top-level Entity Name
                                  Control_extra
Family
                                  Cyclone II
                                  EP2C35F672C6
Device
Timing Models
                                  Final
Met timing requirements
                                  Yes
Total logic elements
                                  2/33,216(<1%)
  Total combinational functions
                                  2/33,216(<1%)
  Dedicated logic registers
                                  1/33,216 (< 1%)
Total registers
Total pins
                                  11/475(2%)
Total virtual pins
Total memory bits
                                  0 / 483,840 (0%)
Embedded Multiplier 9-bit elements
                                  0/70(0%)
Total PLLs
                                  0/4(0%)
```

# 3.4 AperB actualitzat

En aquest modul cal afegir les funcionalitats de la part c extra que seran les de multiplicar A\*A, B\*B i la suma A+B. El component l'hem fet amb vhdl, pero com que el codi es molt llarg ja que cobrim molts casos i s'han de convertir totes les respostes a BCD. Per tant mostrarem una petita porcio del codi suficient per a entendre el funcionament.

```
signal AxB_prov: std_logic_vector(7 downto 0);
signal AxA_prov : std_logic_vector(7 downto 0);
signal BxB_prov: std_logic_vector(7 downto 0);
signal AmesB_prov : std_logic_vector(7 downto 0);
OpA2 <= "0000" & OpA;
OpB2 <= "0000" & OpB;
 AxB_prov <= OpA*OpB;
AxA_prov <= OpA*OpA;
BxB_prov <= OpB*OpB;
 AmesB_prov \le OpA2 + OpB2;
                              with AxB-prov select AxB <=  "10011001" \text{ WHEN "} "01010001" , ... 81 \\ "01110010" \text{ WHEN "} "010010000" , ... 72 \\ "01100100" \text{ WHEN "} "010000000" , ... 64 \\ "01010110" \text{ WHEN "} "00111000" , ... 56 \\ "010101001" \text{ WHEN "} "00110110" , ... 54 \\ "010010010" \text{ WHEN "} "00110000" , ... 49 \\ "010010000" \text{ WHEN "} "00110000" , ... 48 \\ "0100100101" \text{ WHEN "} "00101101" , ... 45 \\ \end{cases} 
                                                             "_____" WHEN OTHERS;
                               with AxA_prov select AxA <= "10011001" WHEN "01010001" ,—81 "01110010" WHEN "01001000" ,—72
                                                                                                                                                                   ,—72
                                                             "01110010" WHEN "01001000"
"01100100" WHEN "01000000"
"01010110" WHEN "001110100"
"010101000" WHEN "00110110"
"01001001" WHEN "00110001"
"01001000" WHEN "00110000"
"01000101" WHEN "001101101"
                                                                                                                                                                   ,—56
                                                                                                                                                                   ,--54
                                                                                                                                                                   ,—48
                                                                                         —" WHEN OTHERS;
                              with BxB_prov select BxB <=
    "10011001" WHEN "01010001" ,...81
    "01110010" WHEN "010010000" ,...72
    "01100100" WHEN "010000000" ,...64
    "01010110" WHEN "00111000" ,...56
    "010101000" WHEN "00110110" ,...44
    "01001001" WHEN "00110000" ,...48
    "010010101" WHEN "00101101" ,...45
                                                                                      ——" WHEN OTHERS;
                               with AmesB_prov select AmesB <=
                                                             ess_prov select Ames8 <=
"00011000" when "00010010",—18
"00010111" when "00010001",—17
"00010110" when "00010000",—16
"00010101" when "000001111",—15
"00010100" when "00001111",—14
                                                              "———" WHEN OTHERS;
 end arq;
```

Flow Status Successful - Thu Nov 12 16:05:15 2020 Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition Revision Name Practica2\_2 Top-level Entity Name AperB\_extra Family Cyclone II EP2C35F672C6 Device Timing Models Final Yes Met timing requirements Total logic elements 137 / 33,216 (< 1 %) Total combinational functions 137 / 33,216 (< 1 %) Dedicated logic registers 0/33,216(0%) Total registers 0 Total pins 40 / 475 (8%) Total virtual pins Total memory bits 0 / 483,840 (0%) Embedded Multiplier 9-bit elements 0/70(0%) Total PLLs 0/4(0%)



La simulacio mostra que els calculs s'efectuen correctament en tots els casos.

#### 3.5 MUX de 4 entrades

Aquest component decidirà la sortida en funció de si introduim A, B, C o D a la placa durant la fase de show.

```
library ieee;
use ieee.std_logic_1164.all;
entity MUX_extra is
```

Successful - Thu Nov 12 16:06:34 2020 Flow Status Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition Revision Name Practica2\_2 Top-level Entity Name MUX\_extra Family Cyclone II Device EP2C35F672C6 Timing Models Final Met timing requirements Yes 33 / 33,216 (< 1 %) Total logic elements Total combinational functions 33 / 33,216 (< 1 %) Dedicated logic registers 0/33,216(0%) Total registers Total pins 44 / 475 (9%) Total virtual pins Total memory bits 0 / 483,840 (0%) Embedded Multiplier 9-bit elements 0 / 70 (0%) Total PLLs 0/4(0%)



Podem veure que funciona ja que en funcio de la entrada sel ens mostra la entrada desitjada.

#### 3.6 Programa principal extra

Aquest funciona molt semblant al de la part 1. Rep la tecla premuda que desxifra a trabes de keycode\_extra. Aquesta tecla la passa a control que actualitza les dades de estat i activa o no els bits de intro i show.

Per altra banda regs\_extra2 rep la informacio de la tecla premuda i de si es A o si es B, junt amb si control esta en el estat d'entrar dades o no ho esta. Si es A actualitza el estat de la mateixa manera que si es B. En el cas que que intro sigui 1 i keycode sigui un valor BCD s'actualitza la variable que toqui en funcio del estat. Aquestes dos sortides, opA i opB s'introdueixen dins de la calculadora que ens fa totes les operacions. A la sortida es conecta amb el multiplexor que en funció de la tecla premuda despres d'activar el bit show mostrara una cosa o altra. Finalment el bloc Sel decideix si mostrar o no la sortida en funcio de si esta activat el bit show o no.



Flow Status Successful - Thu Nov 12 16:08:00 2020

Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

Revision Name Practica2\_2
Top-level Entity Name ppal\_extra
Family Cyclone II

Device EP2C35F672C6

Timing Models Final Met timing requirements No

 Total logic elements
 213 / 33,216 ( < 1 % )</td>

 Total combinational functions
 213 / 33,216 ( < 1 % )</td>

 Dedicated logic registers
 9 / 33,216 ( < 1 % )</td>

Total registers 9

Total pins 26 / 475 (5 %)

Total virtual pins 0

Total memory bits 0 / 483,840 (0 %)
Embedded Multiplier 9-bit elements 0 / 70 (0 %)
Total PLLs 0 / 4 (0 %)



Per veure si funcionava hem simulat les seguents entrades. Primer introduim un asterisc per a marcar l'inici de les entrades. Despres marquem que volem entrar els valors de B, que introduim el nombre 4 i despres el 6. Despres indiquem que volem introduir els nombres dins de A, al qual introduim el nombre 3. Despres clicant coixinet activem el bit de show. Clicant A ens mostra A\*B, clicant B ens mostra A\*A, clicant C ens mostra B\*B i clicant D ens mostra A+B. Per tant el diseny funciona a la perfecció.

#### 4 Part extra 2

Aquesta part cobreix la explicacio de la part b del extra. Tot i que tenim una idea de com es fa, no hem tingut temps de debuguejar tot el codi i simularho. Tot i així mostrarem els components casi complets i com seria el seu funcionament en el cas de que estiguessin construits bé.

## 4.1 Regs actualitzat

Per tal de saber si s'entrarà un nombre positiu o negatiu hem afegit dos nous estats, entrAmenys i entrBmenys. Aquest gestionaran la entrada en el cas que sigui negativa. Si estem en aquest estat i s'entra una dada, s'aplicarà una conversió de BCD a CA2 i es treurà el resultat. El codi seria semblant al seguent.

```
if nrst='0' then state <= entrAmes;
          end if;
                   when entrAmes => if B = '1' and (intro = '1') then state <= entrBmes;
                                        elsif C = '1' and (intro = '1') then state <= entrAmenys;
                                        end if;
                                     => if A = '1' and (intro = '1') then state <= entrAmes;
                    when entrBmes
                                        elsif C = '1' and (intro = '1') then state <= entrBmenys
                   when entrAmenys => if B = '1' and (intro = '1') then state <= entrBmenys elsif A = '1' and (intro = '1') then state <= entrAmes; end if;
                    when entrBmenys => if A = '1' and (intro = '1') then state <= entrAmes; elsif B = '1' and (intro = '1') then state <= entrBmes; end if;
         end case;
          case state is
                    when entrAmes => if (nrst = '0') then aux1 <= "0000";
                                                                                           aux2 <= "0000";
                                                   elsif(nrst='1') and (intro = '1') then
                                          aux1 <= keycode;
end if;
if(nrst = '0') then aux1 <= "00000";
                    when entrBmes =>
                                                                                            aux2 <= "0000";
                                                  elsif ((nrst='1') and (intro='1')) then
                                                                     aux2 <= keycode;
                                                            end if;
                                             if(nrst = '0')then aux1 <= "0000";
                    when entrAmenvs =>
                                                  aux2 <= "0000"; \\ elsif(nrst='1') \quad \text{and} \ (intro='1') \ then
                                                           aux1 <= (Aqui aniria keycode en CA2); end if;
                                             if (nrst = '0') then aux1 <= "0000";

aux2 <= "0000";

elsif (nrst='1') and (intro = '1') then
                    when entrBmenvs =>
                                                            aux2(0) <= (Aqui aniria keycode en CA2);
                                                            end if;
end process;
opA <= aux1;
opB <= aux2;
end arq;
```

# 4.2 AperB

Aquest component caldrà actualitzarlo per tal de fer les operacions en signed decimal. El codi sera el mateix, però canviaran les seguents linees.

```
USE IEEE.NUMERIC.STD.ALL;

...
AxB_prov <= signed (OpA)*signed (OpB);
AxA_prov <= OpA*OpA;
BxB_prov <= OpB*OpB;
AmesB_prov <= signed (OpA2) + signed (OpB2);
```

# 4.3 Signe 7s

Finalment per afegir el signe hem fet una descripció vhdl del modul Signe 7s i amb el modul de Signe 7s i a partir dels interuptors SW i una porta XOR aconseguim el resultat desitjat. Hem posat una entrada num i una

altra entrada show de tal manera que quan introduirem numeros per teclat el signe estigui apagat .



Flow Status Successful - Thu Nov 12 18:11:45 2020

Quartus II Version 9.1 Build 350 03/24/2010 SP 2 SJ Web Edition

 Revision Name
 Practica2\_2

 Top-level Entity Name
 Signe\_7s

 Family
 Cyclone II

 Device
 EP2C35F672C6

Timing Models Final
Met timing requirements Yes

 Total logic elements
 1 / 33,216 ( < 1 % )</td>

 Total combinational functions
 1 / 33,216 ( < 1 % )</td>

 Dedicated logic registers
 0 / 33,216 ( 0 % )

Total registers 0

Total pins 9 / 475 (2 %)

Total virtual pins 0

Total memory bits 0 / 483,840 (0 %)
Embedded Multiplier 9-bit elements 0 / 70 (0 %)
Total PLLs 0 / 4 (0 %)